<template>
	<div v-if="proxy.isAuth(['ROOT', 'USER:SELECT'])">
	    <el-form :inline="true" :model="dataForm" :rules="dataRule" ref="form">
	        <el-form-item prop="name">
	            <el-input v-model="dataForm.name" placeholder="姓名"
	                maxlength="10" class="input" clearable="clearable" />
	        </el-form-item>
	        <el-form-item>
	            <el-select v-model="dataForm.sex" class="input" placeholder="性别"
	                clearable="clearable">
	                <el-option label="男" value="男" />
	                <el-option label="女" value="女" />
	            </el-select>
	        </el-form-item>
	        <el-form-item>
	            <el-select v-model="dataForm.role" class="input"
	                placeholder="角色" clearable="clearable">
	                <el-option v-for="one in dataForm.roleList"
	                    :label="one.roleName" :value="one.roleName" />
	            </el-select>
	        </el-form-item>
	        <el-form-item>
	            <el-select v-model="dataForm.deptId" class="input"
	                placeholder="部门" clearable="clearable">
	                <el-option v-for="one in dataForm.deptList"
	                    :label="one.deptName" :value="one.id" />
	            </el-select>
	        </el-form-item>
	        <el-form-item>
	            <el-select v-model="dataForm.status" class="input"
	                placeholder="状态" clearable="clearable">
	                <el-option label="在职" value="1" />
	                <el-option label="离职" value="2" />
	            </el-select>
	        </el-form-item>
	        <el-form-item>
	            <el-button type="primary" @click="searchHandle()">查询</el-button>
	            <el-button type="primary"
	                :disabled="!proxy.isAuth(['ROOT', 'USER:INSERT'])"
	                @click="addHandle()">
	                新增
	            </el-button>
	            <el-button type="danger"
	                :disabled="!proxy.isAuth(['ROOT', 'USER:DELETE'])"
	                @click="deleteHandle()">
	                批量删除
	            </el-button>
	        </el-form-item>
	    </el-form>
		  <el-table :data="data.dataList"
		        :header-cell-style="{'background':'#f5f7fa'}" border
		        v-loading="data.loading" @selection-change="selectionChangeHandle">
            <el-table-column type="selection" header-align="center"
                :selectable="selectable" align="center" width="50" />

		        <el-table-column type="index" header-align="center" align="center"
		            width="60" label="序号">
		            <template #default="scope">
		                <span>{{ (data.pageIndex - 1) * data.pageSize + scope.$index + 1 }}</span>
		            </template>
		        </el-table-column>
		        <el-table-column prop="name" header-align="center" align="center"
		            min-width="100" label="姓名" />
		        <el-table-column prop="sex" header-align="center" align="center"
		            min-width="60" label="性别" />
		        <el-table-column prop="tel" header-align="center" align="center"
		            min-width="130" label="电话" />
		        <el-table-column prop="email" header-align="center" align="center"
		            min-width="200" label="邮箱" :show-overflow-tooltip="true" />
		        <el-table-column prop="hiredate" header-align="center"
		            align="center" min-width="130" label="入职日期" />
		        <el-table-column prop="roles" header-align="center" align="center"
		            min-width="100" label="角色" :show-overflow-tooltip="true" />
		        <el-table-column prop="dept" header-align="center" align="center"
		            min-width="100" label="部门" />
		        <el-table-column prop="status" header-align="center" align="center"
		            min-width="80" label="状态" />
		        <el-table-column header-align="center" align="center" width="150"
		            label="操作">
		            <template #default="scope">
		                <el-button type="text"
		                    v-if="proxy.isAuth(['ROOT', 'USER:UPDATE'])"
		                    @click="updateHandle(scope.row.id)">
		                    修改
		                </el-button>
		                <el-button type="text"
		                    v-if="proxy.isAuth(['ROOT', 'USER:UPDATE'])"
		                    :disabled="scope.row.status == '离职' || scope.row.root"
		                    @click="dismissHandle(scope.row.id)">
		                    离职
		                </el-button>
		                <el-button type="text" :disabled="scope.row.root"
		                    v-if="proxy.isAuth(['ROOT', 'USER:DELETE'])"
		                    @click="deleteHandle(scope.row.id)">
		                    删除
		                </el-button>
		            </template>
		        </el-table-column>
      </el-table>
      <el-pagination @size-change="sizeChangeHandle"
		        @current-change="currentChangeHandle" :current-page="data.pageIndex"
		        :page-sizes="[10, 20, 50]" :page-size="data.pageSize"
		        :total="data.totalCount"
		        layout="total, sizes, prev, pager, next, jumper"></el-pagination>
	</div>
  <el-dialog :title="!dialog.dataForm.id ? '新增' : '修改'"
             v-if="proxy.isAuth(['ROOT', 'USER:INSERT', 'USER:UPDATE'])"
             :close-on-click-modal="false" v-model="dialog.visible" width="450px">
    <el-form :model="dialog.dataForm" ref="dialogForm"
             :rules="dialog.dataRule" label-width="80px">
      <el-form-item label="用户名" prop="username">
        <el-input v-model="dialog.dataForm.username" maxlength="20"
                  clearable />
      </el-form-item>
      <el-form-item label="密码" prop="password" v-if="!dialog.update">
        <el-input type="password" v-model="dialog.dataForm.password"
                  maxlength="20" clearable />
      </el-form-item>
      <el-form-item label="姓名" prop="name">
        <el-input v-model="dialog.dataForm.name" maxlength="10"
                  clearable />
      </el-form-item>
      <el-form-item label="性别" prop="sex">
        <el-select v-model="dialog.dataForm.sex" clearable>
          <el-option label="男" value="男"></el-option>
          <el-option label="女" value="女"></el-option>
        </el-select>
      </el-form-item>
      <el-form-item label="电话" prop="tel">
        <el-input v-model="dialog.dataForm.tel" maxlength="11"
                  clearable />
      </el-form-item>
      <el-form-item label="邮箱" prop="email">
        <el-input v-model="dialog.dataForm.email" maxlength="200"
                  clearable />
      </el-form-item>
      <el-form-item label="入职日期" prop="hiredate">
        <el-date-picker v-model="dialog.dataForm.hiredate" type="date"
                        placeholder="选择日期" :editable="false" format="YYYY-MM-DD"
                        value-format="YYYY-MM-DD" class="dialog-input" />
      </el-form-item>
      <el-form-item label="角色" prop="role">
        <el-select v-model="dialog.dataForm.role" placeholder="选择角色"
                   class="dialog-input" multiple clearable>
          <el-option v-for="one in dataForm.roleList" :key="one.id"
                     :label="one.roleName" :value="one.id"
                     :disabled="one.roleName == '超级管理员'"></el-option>
        </el-select>
      </el-form-item>
      <el-form-item label="部门">
        <el-select v-model="dialog.dataForm.deptId" placeholder="选择部门"
                   class="dialog-input" clearable>
          <el-option v-for="one in dataForm.deptList" :key="one.id"
                     :label="one.deptName" :value="one.id" />
        </el-select>
      </el-form-item>
    </el-form>
    <template #footer>
        <span class="dialog-footer">
            <el-button @click="dialog.visible = false">取消</el-button>
            <el-button type="primary" @click="dataFormSubmit">确定</el-button>
        </span>
    </template>
  </el-dialog>

</template>

<script lang="ts" setup>
    import { reactive, getCurrentInstance, ref, onMounted } from 'vue';
    const { proxy } = getCurrentInstance();
    import { dayjs } from 'element-plus';

    const dataForm = reactive({
        name: '',
        sex: '',
        role: '',
        deptId: '',
        status: '',
        roleList: [],
        deptList: []
    });
    const dataRule = reactive({
        name: [{ required: false, pattern: '^[\u4e00-\u9fa5]{1,10}$', message: '姓名格式错误' }]
    });
	
	  const data = reactive({
		dataList: [],
		pageIndex: 1,
		pageSize: 10,
		totalCount: 0,
		loading: false,
		selections: []
	});

	  const dialog = reactive({
	        visible: false,
	        update: false,
	        dataForm: {
	            id: null,
	            username: null,
	            password: null,
	            name: null,
	            sex: null,
	            tel: null,
	            email: null,
	            hiredate: dayjs(new Date()).format('YYYY-MM-DD'),
	            role: null,
	            deptId: null,
	            status: 1
	        },
	        dataRule: {
	            username: [
	                { required: true, message: '用户名不能为空' },
	                { pattern: '^[a-zA-Z0-9]{5,20}$', message: '用户名格式错误' }
	            ],
	            password: [
	                { required: true, message: '密码不能为空' },
	                { pattern: '^[a-zA-Z0-9]{6,20}$', message: '密码格式错误' }
	            ],
	            name: [
	                { required: true, message: '姓名不能为空' },
	                { pattern: '^[\u4e00-\u9fa5]{2,10}$', message: '姓名格式错误' }
	            ],
	            sex: [{ required: true, message: '性别不能为空' }],
	            tel: [{ required: true, message: '电话不能为空' }, { pattern: '^1[1-9]\\d{9}$', message: '电话格式错误' }],
	            email: [
	                { required: true, message: '邮箱不能为空' },
	                { pattern: '^([a-zA-Z]|[0-9])(\\w|\\-)+@[a-zA-Z0-9]+\\.([a-zA-Z]{2,4})$', message: '邮箱格式错误' }
	            ],
	            hiredate: [{ required: true, message: '入职日期不能为空' }],
	            role: [{ required: true, message: '角色不能为空' }],
	            status: [{ required: true, message: '状态不能为空' }]
	        }
    });

    function loadRoleList() {
      proxy.$http('/mis/role/searchAllRole', 'GET', null, true, function (resp) {
        dataForm.roleList = resp.list;
      });
    }
    function loadDeptList() {
      proxy.$http('/mis/dept/searchAllDept', 'GET', null, true, function (resp) {
        dataForm.deptList = resp.list;
      });
    }
    //执行两个封装函数
    loadRoleList();
    loadDeptList();

    function loadDataList() {
      data.loading = true;
      let json = {
        page: data.pageIndex,
        length: data.pageSize,
        name: dataForm.name,
        sex: dataForm.sex,
        role: dataForm.role,
        deptId: dataForm.deptId,
        status: dataForm.status
      };
      proxy.$http('/mis/user/searchByPage', 'POST', json, true, function (resp) {
        let page = resp.page;
        let list = page.list;
        for (let one of list) {
          if (one.status == 1) {
            one.status = '在职';
          } else if (one.status == 2) {
            one.status = '离职';
          }
        }
        data.dataList = list;
        data.totalCount = page.totalCount;
        data.loading = false;
      });
    }
    //调用封装函数，加载分页记录
    loadDataList();

    function searchHandle() {
      proxy.$refs['form'].validate(valid => {
        if (valid) {
          //清理验证结果
          proxy.$refs['form'].clearValidate();
          //把空字符串替换成null值
          if (dataForm.name == '') {
            dataForm.name = null;
          }
          //默认显示第一页数据
          if (data.pageIndex != 1) {
            data.pageIndex = 1;
          }
          //调用封装函数，加载分页记录
          loadDataList();
        } else {
          return false;
        }
      });
    }

    function sizeChangeHandle(val) {
      data.pageSize = val;
      data.pageIndex = 1;
      loadDataList();
    }
    function currentChangeHandle(val) {
      data.pageIndex = val;
      loadDataList();
    }

    function addHandle() {
      dialog.dataForm.id = null;
      dialog.update = false;
      dialog.visible = true;
      proxy.$nextTick(() => {
        proxy.$refs['dialogForm'].resetFields();
      });
    }

    function dataFormSubmit() {
      proxy.$refs['dialogForm'].validate(valid => {
        if (valid) {
          let json = {
            userId: dialog.dataForm.id,
            username: dialog.dataForm.username,
            password: dialog.dataForm.password,
            name: dialog.dataForm.name,
            sex: dialog.dataForm.sex,
            tel: dialog.dataForm.tel,
            email: dialog.dataForm.email,
            //把日期对象转换成日期字符串
            hiredate: dayjs(dialog.dataForm.hiredate).format('YYYY-MM-DD'),
            role: dialog.dataForm.role,
            deptId: dialog.dataForm.deptId,
            status: dialog.dataForm.status
          };
          // console.log(json);
          proxy.$http(`/mis/user/${dialog.dataForm.id == null ? 'insert' : 'update'}`, 'POST', json, true, function (resp) {
            if (resp.rows == 1) {
              proxy.$message({
                message: '操作成功',
                type: 'success',
                duration: 1200,
                onClose: () => {
                  dialog.visible = false;
                  //重新加载分页数据
                  loadDataList();
                }
              });

            } else {
              proxy.$message({
                message: '操作失败',
                type: 'error',
                duration: 1200
              });
            }
          });
        }
      });
    }

    function updateHandle(id) {
      dialog.dataForm.id = id;
      dialog.update = true;
      dialog.visible = true;
      //先把弹窗显示出来，再发送Ajax请求，加载用户信息
      proxy.$nextTick(() => {
        let json = {
          userId: id
        };
        proxy.$http('/mis/user/searchById', 'POST', json, true, function (resp) {
          let result = resp.result;
          dialog.dataForm.username = result.username;
          dialog.dataForm.name = result.name;
          dialog.dataForm.sex = result.sex;
          dialog.dataForm.tel = result.tel;
          dialog.dataForm.email = result.email;
          dialog.dataForm.hiredate = result.hiredate;
          dialog.dataForm.role = JSON.parse(result.role);
          dialog.dataForm.deptId = result.deptId;
          dialog.dataForm.status = result.status;
        });
      });
    }

    function selectable(row, index) {
      let temp=row.roles.split("，")
      if (temp.includes("超级管理员")) {
        return false;
      }
      return true;
    }

    function selectionChangeHandle(val) {
      //console.log(val)
      data.selections = val;
    }

    function deleteHandle(id) {
      let ids = id ? [id] : data.selections.map(item => {
        return item.id;
      });
      if (ids.length == 0) {
        proxy.$message({
          message: '没有选中记录',
          type: 'warning',
          duration: 1200
        });
      } else {
        proxy.$confirm('确定要删除选中的记录？', '提示', {
          confirmButtonText: '确定',
          cancelButtonText: '取消',
          type: 'warning'
        })
            .then(() => {
              proxy.$http('/mis/user/deleteByIds', 'POST', { ids: ids }, true, function (resp) {
                if (resp.rows > 0) {
                  proxy.$message({
                    message: '操作成功',
                    type: 'success',
                    duration: 1200,
                    onClose: () => {
                      loadDataList();
                    }
                  });
                } else {
                  proxy.$message({
                    message: '未能删除记录',
                    type: 'warning',
                    duration: 1200
                  });
                }
              });
            });
      }
    }

    function dismissHandle(id) {
      proxy.$confirm(`确定设置该用户为离职状态？`, '提示', {
        confirmButtonText: '确定',
        cancelButtonText: '取消',
        type: 'warning'
      }).then(() => {
        let json = { userId: id }
        proxy.$http('/mis/user/dismiss', 'POST', json, true, function (resp) {
          if (resp.rows == 1) {
            proxy.$message({
              message: '操作成功',
              type: 'success',
              duration: 1200,
              onClose: () => {
                loadDataList();
              }
            });
          } else {
            proxy.$message({
              message: '操作失败',
              type: 'warning',
              duration: 1200
            });
          }
        });
      });
    }

</script>


<style lang="less" scoped>
    .dialog-input {
        width: 100% !important;
    }
</style>
